home *** CD-ROM | disk | FTP | other *** search
/ CD-ROM Now 11 / CD-ROM Now MegaDisc 11 (1995-02).iso / discs / cica / winben.exe / WINBENCH.MS_ / WINBENCH.MS
Text File  |  1993-10-25  |  8KB  |  286 lines

  1. '**************************************************************************
  2. '*                       MSSetup Toolkit Sample 1
  3. '**************************************************************************
  4.  
  5. '$DEFINE DEBUG  ''Define for script development/debugging
  6.  
  7. '$INCLUDE 'setupapi.inc'
  8. '$INCLUDE 'msdetect.inc'
  9.  
  10. ''Dialog ID's
  11. CONST WELCOME       = 100
  12. CONST ASKQUIT       = 200
  13. CONST DESTPATH      = 300
  14. CONST EXITFAILURE   = 400
  15. CONST EXITQUIT      = 600
  16. CONST EXITSUCCESS   = 700
  17. CONST EXITRESTART   = 750
  18. CONST OPTIONS       = 800
  19. CONST APPHELP       = 900
  20. CONST BADPATH       = 6400
  21.  
  22. CONST TRUE        = -1
  23. CONST FALSE        = 0
  24.  
  25. ''Bitmap ID
  26. CONST LOGO = 1
  27.  
  28. GLOBAL DEST$        ''Default destination directory.
  29. GLOBAL OPTCUR$      ''Option selection from option dialog.
  30. GLOBAL DestDrive$
  31. GLOBAL PRODUCTNAME$
  32. GLOBAL WinDrive$
  33.  
  34. DECLARE SUB Install
  35. DECLARE FUNCTION CheckSpace () AS INTEGER
  36. DECLARE FUNCTION MakePath (szDir$, szFile$) AS STRING
  37.  
  38.  
  39. INIT:
  40.     PRODUCTNAME$ = "WinBench 4.0"
  41.     CUIDLL$ = "mscuistf.dll"            ''Custom user interface dll
  42.     HELPPROC$ = "FHelpDlgProc"          ''Help dialog procedure
  43.  
  44.     SetBitmap CUIDLL$, LOGO
  45.     SetTitle PRODUCTNAME$ + " Setup"
  46.  
  47.     szInf$ = GetSymbolValue("STF_SRCINFPATH")
  48.     IF szInf$ = "" THEN
  49.         szInf$ = MakePath(GetSymbolValue("STF_CWDDIR"),"WINBENCH.INF")
  50.     END IF
  51.     ReadInfFile szInf$
  52.  
  53.     OPTCUR$ = "1"
  54.     DEST$ = "C:\WINBENCH"
  55.  
  56.     WinDrive$ = MID$(GetWindowsDir, 1, 1)
  57.     IF IsDriveValid(WinDrive$) = 0 THEN
  58.         i% = DoMsgBox("Windows drive ('"+WinDrive$+"') is not a valid drive.", "DEBUG", MB_TASKMODAL+MB_ICONHAND+MB_OK)
  59.         GOTO QUIT
  60.     END IF
  61.  
  62. WELCOME:
  63.     sz$ = UIStartDlg(CUIDLL$, WELCOME, "FInfoDlgProc", APPHELP, HELPPROC$)
  64.     IF sz$ = "CONTINUE" THEN
  65.         UIPop 1
  66.     ELSE
  67.         GOSUB ASKQUIT
  68.         GOTO WELCOME
  69.     END IF
  70.  
  71. GETPATH:
  72.     SetSymbolValue "EditTextIn", DEST$
  73.     SetSymbolValue "EditFocus", "END"
  74. GETPATHL1:
  75.     sz$ = UIStartDlg(CUIDLL$, DESTPATH, "FEditDlgProc", APPHELP, HELPPROC$)
  76.     DEST$ = GetSymbolValue("EditTextOut")
  77.  
  78.     IF sz$ = "CONTINUE" THEN
  79.         DestDrive$ = MID$(DEST$, 1, 1)
  80.         IF IsDriveValid(DestDrive$) = 0 THEN
  81.         GOSUB BADPATH
  82.             GOTO GETPATHL1
  83.         END IF
  84.         IF IsDirWritable(DEST$) = 0 THEN
  85.             GOSUB BADPATH
  86.             GOTO GETPATHL1
  87.         END IF
  88.         UIPop 1
  89.     ELSEIF sz$ = "REACTIVATE" THEN
  90.         GOTO GETPATHL1
  91.     ELSEIF sz$ = "BACK" THEN
  92.         GOTO GETPATHL1
  93.     ELSE
  94.         GOSUB ASKQUIT
  95.         GOTO GETPATH
  96.     END IF
  97.  
  98.     IF CheckSpace() = FALSE THEN
  99.     GOTO GETPATH
  100.     END IF
  101.  
  102.     Install
  103.  
  104.  
  105. QUIT:
  106.     ON ERROR GOTO ERRQUIT
  107.  
  108.     IF ERR = 0 THEN
  109.         IF RestartListEmpty() = 0 THEN
  110.         dlg% = EXITRESTART
  111.         ELSE
  112.             dlg% = EXITSUCCESS
  113.         END IF
  114.     ELSEIF ERR = STFQUIT THEN
  115.         dlg% = EXITQUIT
  116.     ELSE
  117.         dlg% = EXITFAILURE
  118.     END IF
  119. QUITL1:
  120.     sz$ = UIStartDlg(CUIDLL$, dlg%, "FInfo0DlgProc", 0, "")
  121.     IF sz$ = "REACTIVATE" THEN
  122.         GOTO QUITL1
  123.     END IF
  124.     UIPop 1
  125.  
  126.     IF dlg% = EXITRESTART THEN
  127.     j% = ExitExecRestart()
  128.     END IF
  129.     END
  130.  
  131. ERRQUIT:
  132.     i% = DoMsgBox("Setup sources were corrupted, call ZDBOp!", "Setup Message", MB_OK+MB_TASKMODAL+MB_ICONHAND)
  133.     END
  134.  
  135.  
  136.  
  137. BADPATH:
  138.     sz$ = UIStartDlg(CUIDLL$, BADPATH, "FInfo0DlgProc", 0, "")
  139.     IF sz$ = "REACTIVATE" THEN
  140.         GOTO BADPATH
  141.     END IF
  142.     UIPop 1
  143.     RETURN
  144.  
  145.  
  146.  
  147. ASKQUIT:
  148.     sz$ = UIStartDlg(CUIDLL$, ASKQUIT, "FQuitDlgProc", 0, "")
  149.  
  150.     IF sz$ = "EXIT" THEN
  151.         UIPopAll
  152.         ERROR STFQUIT
  153.     ELSEIF sz$ = "REACTIVATE" THEN
  154.         GOTO ASKQUIT
  155.     ELSE
  156.         UIPop 1
  157.     END IF
  158.     RETURN
  159.  
  160.  
  161.  
  162. '**
  163. '** Purpose:
  164. '**     Builds the copy list and performs all installation operations.
  165. '** Arguments:
  166. '**     none.
  167. '** Returns:
  168. '**     none.
  169. '*************************************************************************
  170. STATIC FUNCTION CheckSpace() AS INTEGER
  171.  
  172.     SrcDir$ = GetSymbolValue("STF_SRCDIR")
  173.  
  174.     ClearCopyList
  175.  
  176.     AddSectionFilesToCopyList "Files", SrcDir$, DEST$
  177.     AddSectionFilesToCopyList "System", SrcDir$, GetWindowsSysDir()
  178.     AddSectionFilesToCopyList "Suites", SrcDir$, MakePath(DEST$,"SUITES")
  179.     AddSectionFilesToCopyList "Results", SrcDir$, MakePath(DEST$,"RESULTS")
  180.     AddSectionFilesToCopyList "Doc", SrcDir$, MakePath(DEST$,"DOC")
  181.  
  182.     FOR i% = 1 TO 26 STEP 1
  183.         AddListItem "EXTRA", "0"
  184.     NEXT i%
  185.  
  186.     wd% = ASC(ucase$(WinDrive$)) - ASC("A") + 1
  187.     dd% = ASC(ucase$(DestDrive$)) - ASC("A") + 1
  188.  
  189.     ReplaceListItem "EXTRA", wd%, "10240"
  190.  
  191.     spaceNeeded& = GetCopyListCost("EXTRA","COST","NEEDED")
  192.     IF spaceNeeded& = 0 THEN
  193.     CheckSpace = TRUE
  194.     ELSE
  195.     CheckSpace = FALSE
  196.     w& = VAL(GetListItem("NEEDED",wd%))
  197.     d& = VAL(GetListItem("NEEDED",dd%))
  198.     m$ = "There is not enough disk space to install WinBench."
  199.     IF d& > 0 THEN
  200.         m$ = m$ + CHR$(10) + CHR$(10)
  201.         m$ = m$ + "You need an additional " + STR$((d&+999)/1000) + " kilobytes on drive " + DestDrive$ + "."
  202.             m$ = m$ + " Choose another installation drive, or free additional space on drive " + DestDrive$ + "."
  203.         END IF
  204.     IF (w& > 0) AND (wd% <> dd%) THEN
  205.         m$ = m$ + CHR$(10) + CHR$(10)
  206.         m$ = m$ + "You must free an additional " + STR$((w&+999)/1000) + " kilobytes on drive " + WinDrive$
  207.             m$ = m$ + " before installing WinBench."
  208.     END IF
  209.     i% = DoMsgBox(m$,"Insufficient Disk Space",MB_TASKMODAL+MB_OK+MB_ICONHAND)
  210.     END IF
  211.  
  212.  
  213. END FUNCTION
  214.  
  215. STATIC SUB Install
  216.  
  217.     CreateDir DEST$, cmoNone
  218.     CreateDir MakePath(DEST$,"SUITES"), cmoNone
  219.     CreateDir MakePath(DEST$,"RESULTS"), cmoNone
  220.     CreateDir MakePath(DEST$,"DOC"), cmoNone
  221.  
  222.     SetRestartDir DEST$
  223.  
  224.     LabFile$ = MakePath(DEST$,"WBLAB.DLL")
  225.     IF DoesFileExist(LabFile$,femExists) = 1 THEN
  226.         RemoveFile LabFile$,cmoNone
  227.     END IF
  228.  
  229.     CopyFilesInCopyList
  230.  
  231.     unName$ = MakePath(DEST$, "UNINSTAL.BAT")
  232.  
  233.     un% = FreeFile
  234.     OPEN unName$ FOR APPEND AS # un%
  235.     PRINT # un%, ""
  236.     PRINT # un%, "SET WINDIR=" + MakePath(GetWindowsDir(),"")
  237.     PRINT # un%, "SET SYSDIR=" + MakePath(GetWindowsSysDir(),"")
  238.     PRINT # un%, "SET WBDIR=" + MakePath(DEST$,"")
  239.     PRINT # un%, "SET WBDRIVE=" + DestDrive$
  240.     PRINT # un%, "GOTO START"
  241.     PRINT # un%, ":DONE"
  242.     CLOSE # un%
  243.  
  244.     IniFile$ = MakePath(GetWindowsDir(),"winbench.ini")
  245.     'IF DoesFileExist(IniFile$,femReadWrite) = 1 THEN
  246.     'RemoveFile IniFile$,cmoNone
  247.     'END IF
  248.     IF DoesIniSectionExist(IniFile$,"Registration") THEN
  249.     RemoveIniSection IniFile$,"Registration",cmoNone
  250.     END IF
  251.  
  252.     CreateProgmanGroup "Ziff-Davis Benchmarks", "", cmoNone
  253.     ShowProgmanGroup  "Ziff-Davis Benchmarks", 1, cmoNone
  254.     CreateProgmanItem "Ziff-Davis Benchmarks", PRODUCTNAME$, MakePath(DEST$,"winbench.exe"), "", cmoOverwrit
  255.  
  256. END SUB
  257.  
  258.  
  259.  
  260. '**
  261. '** Purpose:
  262. '**     Appends a file name to the end of a directory path,
  263. '**     inserting a backslash character as needed.
  264. '** Arguments:
  265. '**     szDir$  - full directory path (with optional ending "\")
  266. '**     szFile$ - filename to append to directory
  267. '** Returns:
  268. '**     Resulting fully qualified path name.
  269. '*************************************************************************
  270. FUNCTION MakePath (szDir$, szFile$) STATIC AS STRING
  271.     IF szDir$ = "" THEN
  272.         MakePath = szFile$
  273.     ELSEIF szFile$ = "" THEN
  274.     IF MID$(szDir$, LEN(szDir$), 1) = "\" THEN
  275.         MakePath = MID$(szDir$, 1, LEN(szDir$)-1)
  276.     ELSE
  277.         MakePath = szDir$
  278.     END IF
  279.     ELSEIF MID$(szDir$, LEN(szDir$), 1) = "\" THEN
  280.         MakePath = szDir$ + szFile$
  281.     ELSE
  282.         MakePath = szDir$ + "\" + szFile$
  283.     END IF
  284. END FUNCTION
  285.  
  286.